草庐IT

HTTP 服务器

全部标签

pointers - 为什么 2 个不同的 http.Request 结构的 http.Request.URL.Host 的地址相同?

此代码是大型代码库中的独立示例,用于尝试复制错误。该程序运行时,&request.URL.Host和&request1.URL.Host的地址相同。为什么?据我了解,这是两种不同的结构,因此URL.Host不应具有相同的地址。packagemainimport("crypto/tls""fmt""net/http""net/url")funcmain(){hostname:="www.google.com"uri,err:=url.Parse("http://www.google.com/")iferr!=nil{panic(err)}vartlsConfig*tls.Configtl

sockets - 如何在不阻塞服务器的情况下通过 tcp 向客户端发送数据?

我正在写一个游戏服务器,因为这是我的第一次,我一直想知道如何在不滞后服务器的情况下向客户端发送数据包。即使客户端滞后,也应该向他们发送数据包。(不确定这样做是否正确,但如果我不向他们发送数据包,客户端将不会同步)所以首先我的想法是:每个玩家在连接时都会获得2个goroutines:一个用于发送,另一个用于接收。//intheservermainloopselect{caseplayer.sendChan所以这里服务器的mainloop最多可以无阻塞地向播放器channel发送100个数据包,而sendPacket是阻塞的(可能是由于滞后)。但问题是如果播放器在100个数据包后阻塞,服务

json - 在 render.Bind 中置空 http.Request.Body

我正在使用github.com/pressly/chi构建这个简单的程序,我尝试从http.Request.Body中解码一些JSON:packagemainimport("encoding/json""fmt""net/http""github.com/pressly/chi""github.com/pressly/chi/render")typeTeststruct{Namestring`json:"name"`}func(p*Test)Bind(r*http.Request)error{err:=json.NewDecoder(r.Body).Decode(p)iferr!=ni

go - 设置内置 HTTP 请求超时的最佳方式

在内置httpNewRequest上设置超时的最佳方法是什么?目前,我正在使用覆盖整个交换的http.Client.Timeout,但是是否有更好的东西,例如context.WithDeadline或context.WithTimeout。如果是,它是如何工作的,我如何为http.NewRequest设置一个context.WithDeadline解决方案?这是我目前的解决方案:func(c*Client)post(resourcestring,dataurl.Values,timeouttime.Duration)([]byte,error){url:=c.getURL(resour

go - FileServer 处理程序是否仅服务于您指定目录中的内容?

例如,用户可以将您的url与linux命令一起放在文件夹/目录中吗?假设我的服务器包括:bin/serverfile.go...public/index.htmlstyle.css“www.example.com/../bin/etc”与serverfile.go组成:pacakagemainimport"net/http"funcmain(){htttp.ListenAndServe(":8000",http.FileServer(http.Dir("public")))} 最佳答案 http.FileServer禁止突破您指定的

go - 如何在 golang thrift 服务器中获取客户端的 IP

我正在用golang编写一个thrift服务,我想了解如何在处理函数上下文中获取客户端的IP地址。谢谢,亲爱的。 最佳答案 我想你正在使用这个GodocThriftlibrary.在您的问题中包含代码片段会很好;例如thriftserver的类型,handler定义等根据ThriftGolibrarydoc-func(p*TSocket)Addr()net.AddrReturnstheremoteaddressofthesocket.因此,如果您有权访问TSocket,那么您可以获得远程地址。

rest - 在使用 Auth0 的 golang 服务器中找出当前用户名

我正在使用auth0和golang作为休息服务,其实现与here类似。.我想知道如何找出当前触发某个API调用的用户的名称-例如,如果有人请求http://localhost:3000/products-中的go处理程序这个案例看起来像这样:varProductsHandler=http.HandlerFunc(func(whttp.ResponseWriter,r*http.Request){payload,_:=json.Marshal(products)w.Header().Set("Content-Type","application/json")w.Write([]byte(

go - 将服务帐户 key 文件传递给 bigquery 客户端

我正在尝试将服务帐户与gobigquery客户端一起使用。出于某种原因,在创建客户端时没有Go示例说明如何传递服务文件。我在这里看到https://cloud.google.com/docs/authentication/production但是这种模式不遵循任何显示的内容。它也没有显示在https://godoc.org/cloud.google.com/go/bigquery我有//bigquery_caller.gopackagemainimport"C"import"fmt"import"cloud.google.com/go/bigquery"import"golang.or

http - 戈朗 : strategies to prevent connection reset by peer errors

该程序同时生成许多goroutines(getStock),我相信这会导致远程服务器立即断开连接。我不是要创建DOS,但我仍然想在不出现“连接重置”错误的情况下积极获取数据。最多只能有N(例如20)个同时连接的策略是什么?golang的Http客户端有内置GET请求队列吗?我仍在学习,如果能了解是否有针对此类代码的更好设计模式,那就太好了。输出$goruns1w.gosl(size):1280body:"AAPL",17.92body:"GOOG",32.13body:"FB",42.02body:"AMZN",195.83body:"GOOG",32.13body:"AMZN",19

go - 使用 net/http 将结构值存储在每个请求 Golang 中

我是Golang的新手,我正在测试net/http以运行一些路径,但我遇到了一些我不明白的问题。这是我的代码。packagemainimport("fmt""net/http")typeContentstruct{Datamap[interface{}]interface{}}funcmain(){mux:=http.NewServeMux()mux.Handle("/favicon.ico",http.NotFoundHandler())mux.HandleFunc("/",Index)mux.HandleFunc("/test",Testhandler)http.ListenAnd